

# GMA305KU ±16g Tri-Axial Digital Accelerometer

#### General Introduction

GMA305KU is a tri-axial digital accelerometer with ±16g dynamic range and 13-bit ADC resolution. It integrates a MEMS sensing element and a CMOS conditioning IC in a compact 3×3×1 mm<sup>3</sup> package. The high resolution makes feasible precise applications like e-Compass tilt compensation. The wide sensing range further opens enough windows for motion detection. Finally the small form factor makes it an easy fit-in for compact applications like wearables.

#### **Features**

- O Tri-axial digital accelerometer with  $\pm 16g$  dynamic range
- O 13 bit ADC resolution with sensitivity 256 LSB/g
- O Digital I2C interface supporting both fast mode (400kHz) and normal mode (100kHz)
- O Temperature sensor for internal compensation and capable of digital output
- O Operation voltage:  $+1.7V \sim +3.6V$ ; IO interface voltage:  $+1.7V \sim +3.6V$
- O Power consumption:
  - Continuous mode (CM): typical 140uA to 250uA for 128Hz ODR
  - ➤ Non-Continuous mode (NCM): typical 85uA to 100uA for 1~8Hz ODR
  - ➤ Suspend current < 1uA
- One interrupt pin with selectable polarity and push-pull/open-drain option
- O Built-in functions:
  - Data-ready interrupt
  - ➤ Motion detection: normal and differential modes
  - > Auto-Wake/Sleep transition
  - ➤ 4-tap moving average filter with high-/low-pass option
- O 5000g shock tolerance
- O 16-pin QFN lead-free package. Footprint: 3mm × 3mm, height: 1mm.
- O RoHS compliance

# **Applications**

Smart user interface, e-compass tilt-compensation, motion detection and analysis



Top View



**Bottom View** 



# **Specifications**

Table 1: Pin Descriptions

| Pin# | Name     | Description                    | Pin# | Name | Description                 |
|------|----------|--------------------------------|------|------|-----------------------------|
| 1    | VDDIO    | IO voltage, 1.7~3.6V           | 9    | NC   | No connection inside        |
| 2    | Reserved | Reserved pin, keep unconnected | 10   | GND  | Ground                      |
| 3    | NC       | No connection inside           | 11   | INT  | Interrupt output            |
| 4    | SCL      | I2C serial clock               | 12   | GND  | Ground                      |
| 5    | GND      | Ground                         | 13   | GND  | Ground                      |
| 6    | SDA      | I2C serial data                | 14   | VDD  | Operation voltage, 1.7~3.6V |
| 7    | NC       | No connection inside           | 15   | NC   | No connection inside        |
| 8    | NC       | No connection inside           | 16   | GND  | Ground                      |

Table 2: General Specification

Operation voltage VDD = 3V, environment temperature  $T_a = 25$ °C if not specified otherwise

| Parameter                          | Conditions                                                                          | Min. | Тур.              | Max. | Unit  |
|------------------------------------|-------------------------------------------------------------------------------------|------|-------------------|------|-------|
| Operation voltage (VDD)            | $T_a = -40$ °C ~ +85°C                                                              | 1.7  | 3.0               | 3.6  | V     |
| IO voltage (VDDIO)                 | $T_a = -40^{\circ}C \sim +85^{\circ}C$                                              | 1.7  | _                 | 3.6  | V     |
| CM operating current               | ODR = 128 Hz, low power<br>ODR = 128 Hz, low noise<br>ODR = 128 Hz, high resolution | _    | 140<br>180<br>250 | _    | uA    |
| NCM operating current              | ODR = 8 Hz ODR = 4 Hz ODR = 2 Hz ODR = 1 Hz                                         | 85   | _                 | 100  | uA    |
| Suspend current                    |                                                                                     | _    | 1                 | _    | uA    |
| Dynamic range                      |                                                                                     | _    | ±16               | _    | g     |
| Sensitivity                        |                                                                                     | 230  | 256               | 282  | LSB/g |
| Zero-g offset, calibrated          |                                                                                     | _    | ±60               | _    | mg    |
| Sensitivity to temp.<br>dependency | $T_a = -40$ °C ~ $+85$ °C                                                           | _    | ±0.08             | _    | %/°C  |
| Zero-g offset temp.<br>dependency  | $T_a = -40$ °C ~ $+85$ °C                                                           | _    | ±2                | _    | mg/°C |
| Nonlinearity                       |                                                                                     | _    | ±2                | _    | %FS   |
| Cross axis sensitivity             |                                                                                     | _    | 2                 | _    | %     |



GMA305KU Datasheet V1.1

| Noise                 | _   | 1.1 | _    | mg/√Hz               |
|-----------------------|-----|-----|------|----------------------|
| Operation temperature | -40 | _   | +85  | $^{\circ}\mathrm{C}$ |
| Storage temperature   | -40 | _   | +125 | °C                   |

Table 3: Absolute Maximum Rating

| Parameter                    | Rating                            |
|------------------------------|-----------------------------------|
| V <sub>op</sub> -GND         | -0.3 ~ 4 V                        |
| Any other pin voltage        | GND-0.3 to V <sub>op</sub> +0.3 V |
| Temperature Range (Storage)  | -40°C to +125°C                   |
| ESD                          | 2KV (HBM)                         |
| Mechanical Shock (unpowered) | 5,000 g for 0.2ms                 |
| Freefall on concrete surface | 1.5 m                             |

Note: Stress above the absolute maximum rating as listed in Table 3 may cause permanent damage to the device



# **Block Diagram and Connection**



Figure 1: GMA305KU Block Diagram



7-bit Slave Address is 0x18

Figure 2: GMA305KU I2C Connection Example



## **General Operation**

#### Power-on reset

GMA305KU have a built-in power-on reset (POR) generator. It will reset the core logics and all the registers to default values. There is no limitation on the sequence of switching on the supply voltages of VDD and VDDIO. It is recommended to do a soft reset when VDD and VDDIO are fully applied before the following initialization step. The soft reset can be done by set 1'b1 to RST bit. Please refer to Register 01h[1] for RST bit description.

#### Initialization

GMA305KU will automatically initialize to continuous mode (CM) upon power-up. High-pass filtered acceleration data is available without further setup. Nevertheless the following steps are provided as a reference for further customization. The register description section has more detail information on individual register settings.

- **Step1.** Read the Register 00h (PID) for product ID. The PID value should be 0xA5. Check the I2C connections if the report value is otherwise.
- **Step2.** Write 0x40 to Register 18h. This will turn on the offset temperature compensation.
- **Step3.** Write 0x2A to Register 15h. This will turn on the data ready interrupt and configure the INT pin to active high, push-pull type.
- **Step4.** Write 0x09 to Register 16h. This will turn on the internal low-pass filter. Depending on the application, user may set 0x00 to Register 16h to turn it off, or set 0x12 to Register 16h to turn on the high-pass filter instead.
- **Step5.** The default power scheme is high resolution scheme. Depending on the need, user may set 0x5F to Register 38h to the low noise scheme, or set 0x9F to 38h to the low power scheme.

#### **Operation Modes**

GMA305KU provides two operation modes: the continuous mode (CM) and non-continuous mode (NCM). GMA305KU will automatically power-up to CM. The CM ODR is fixed at 128Hz. The NCM ODR has options of 1/2/4/8Hz, and can be selected by NCLK bits of Register 17h. To switch between these two modes, follow below steps:

- Switch from CM to NCM: Write the byte sequence 0x02, 0x00, 0x08, 0x00 to Register 02h in one I2C transaction. This will first stop DSP and then enter the non-continuous mode.
- Switch from NCM to CM: Write the byte sequence 0x02, 0x00, 0x04, 0x00 to Register 02h in one I2C transaction. This will first stop DSP and then enter the continuous mode.

#### Power-Down Modes

There are two power-down modes: the standby and suspend mode. The DSP is stopped at standby mode, but all register are accessible and their values will be kept intact. The suspend mode will cut most of the chip power, so all registers except Register 01h are not accessible and values may be corrupted after leaving the suspend mode. Follow the steps to switch between



power-down and operation modes:

- Switch from operation to standby mode: Write byte sequence 0x02, 0x00 to Register 02h. This will stop DSP to enter the standby mode.
- Switch from standby mode to operation mode: Write byte sequence 0x04, 0x00 to Register 02h to switch to CM, or write byte sequence 0x08, 0x00 to Register 02h to NCM.
- Switch from operation mode to suspend mode: Write 0x05 to Register 01h. This will power down the on-chip LDO and band-gap circuit.
- Switch from suspend mode to operation mode: Write 0x02 to Register 01h. This will power up the on-chip LDO and band-gap circuit, and reset the chip. Do the usual initialization steps after leaving the suspend mode.

#### Power Schemes for Power-Noise Optimization

GMA305KU provide low power scheme that can be achieved by reducing the oversampling ratio. On the other hand by selecting high oversampling ratio, the noise can be suppressed to improve resolution. GMA305KU provides three oversampling ratios of 64/32/16 that can be configured by the Register 38h. Below table summarizes the settings for the three power schemes. Please refer to register description for more details.

 Register 38h
 Oversampling Ratio
 Power Schemes

 0x1F
 64
 High resolution

 0x5F
 32
 Low noise

 0x9F
 16
 Low power

Table 4: Power Scheme Settings

#### **Motion Detection Function**

Motion detection is used to detect the event when the acceleration reading from any of three axes exceeds a preset threshold. It can be enabled in both CM and NCM operation modes. Interrupt signal can be enabled as well.

Motion detection works in two favors: normal and differential style. In normal detection style, the acceleration reading is checked against the preset threshold directly. When the reading is larger than the threshold value, motion detection is asserted. On the contrary, the differential detection style compares the difference between the current and the previous reading with the threshold value. The detection is asserted when the *difference* is larger than the threshold.

Below summarizes the steps to use motion detection function. For more information on the mentioned registers, see the respective register description.

**Step1.** Set the threshold value to Register 03h. The scale factor for the setting is 1 threshold code = 0.25g.

**Step2.** Select the detection favor between normal and differential styles. For differential style, set 1'b1 to MM\_CM or MM\_NCM bits of Register 16h for CM and NCM mode respectively. Set 1'b0 to MM\_CM or MM\_NCM for normal style instead.



**Step3.** Turn on the motion detection interrupt enable. Set 1'b1 to IMEN\_CM or IMEN\_CM of Register 15h for CM and NCM mode respectively.

#### Auto Wake-up/Sleep

GMA305KU can be configured to automatically transit between CM and NCM mode based on the motion detection function. When the system is not used and does not require high sampling rate, a preset timeout put GMA305KU in sleep/NCM mode to save precious power. It automatically wake-up to CM/high data-rate mode when motion is detected, which usually implies the system begin being used.

Below summarizes the steps to setup auto wake-up/sleep function. For more information on the mentioned registers, see the respective register description.

- **Step1.** Set the timeout value to TOCT bits of Register 17h. The timeout to auto-transit from NCM/sleep to CM/wake-up mode can be set from 0.5 to 6.0 sec.
- **Step2.** Enable the motion detection function following the steps described in the "Motion Detection Function" section. The motion detection is used to enable transition from NCM to CM, so be sure to turn on the motion detection function at NCM.
- Step3. Set 1'b1 to MO\_EN bit of Register 16h to enable the auto-transit from NCM to CM.
- **Step4.** Set 1'b1 to TO\_EN bit of Register 16h to enable the auto timeout transition from CM to NCM.

#### Low-/High-pass Filter

GMA305KU has built-in low-pass and high-pass filter. Use the low-pass filter to remove high-frequency noise, which is particular useful for static acceleration application like e-Compass tilt compensation. The high-pass filter can be used to eliminate the DC offset and low-frequency disturbance, which is helpful in transient application like motion detection. Below summarizes the steps to setup low-/high pass filter. For more information on the mentioned registers, see the respective register description.

- Low-pass filter:
  - Set 1'b1 to MVE\_CM or MVE\_NCM of Register 16h to turn on the 4-tap moving average filer for CM and NCM respectively.
  - Set 1'b0 to HP\_CM or HP\_NCM of Register 16h to turn off the high-pass option and make it low-pass for CM and NCM respectively.
- High-pass filter:
  - Set 1'b1 to MVE\_CM or MVE\_NCM of Register 16h to turn on the 4-tap moving average filer for CM and NCM respectively.
  - Set 1'b1 to HP\_CM or HP\_NCM of Register 16h to turn on the high-pass option and make it high-pass for CM and NCM respectively.



# **User Registers**

# User Register Map

Table 5: User Register Map Table

| Address | bit7               | bit6                                                | bit5     | bit4      | bit3    | bit2    | bit1    | bit0     | Access | Default |
|---------|--------------------|-----------------------------------------------------|----------|-----------|---------|---------|---------|----------|--------|---------|
| 00h     |                    |                                                     |          | PID       | [7:0]   |         |         |          | R      | 0xA5    |
| 01h     |                    |                                                     | Reserved |           |         | PD_BG   | RST     | PD_LDO   | R/W    | 0x00    |
| 02h     | Rese               | erved                                               | Not      | used      |         | ACTI    | R[3:0]  |          | R/W    | 0x00    |
| 03h     | Not used MTHR[4:0] |                                                     |          |           |         |         | )]      |          | R/W    | 0x01    |
| 0.41-   |                    |                                                     |          | STAD      | R[7:0]  |         |         |          | R      | 00055   |
| 04h     |                    |                                                     |          | STADI     | R[15:8] |         |         |          | n.     | 0x0055  |
| 05h     | RST_DP             | ST_DP PG_DONE RD_DONE OTP_VALID Motion CM DAOW DRDY |          |           |         |         |         | R        | NA     |         |
| 06h     |                    |                                                     |          | DX[6:0]   |         |         |         | Not used | R      | NA      |
| 07h     |                    | DX[14:7]                                            |          |           |         |         |         |          | R      | NA      |
| 08h     |                    | DY[6:0] Not used                                    |          |           |         |         |         |          | R      | NA      |
| 09h     |                    |                                                     |          | DY[       | 14:7]   |         |         |          | R      | NA      |
| 0Ah     |                    |                                                     |          | DZ[       | 7:0]    |         |         |          | R      | NA      |
| 0Bh     |                    |                                                     |          | DZ[       | 15:8]   |         |         |          | R      | NA      |
| 0Ch     |                    |                                                     |          | DT[       | 7:0]    |         |         |          | R      | NA      |
| 0Dh     |                    |                                                     |          | DT[       | 15:8]   |         |         |          | R      | NA      |
| 0E~15h  |                    |                                                     |          | Rese      | rved    |         |         |          | _      |         |
| 15h     | Not used           | IMEN_NCM                                            | IDEN_NCM | ITYPE_NCM | IPOL    | IMEN_CM | IDEN_CM | ITYPE_CM | R/W    | 0x4C    |
| 16h     | MO_EN              | TO_EN                                               | MM_NCM   | HP_NCM    | MVE_NCM | MM_CM   | HP_CM   | MVE_CM   | R/W    | 0x1B    |
| 17h     | Reserved           | Reserved TOCT[2:0] NCLK[1:0] Reserved               |          |           |         |         |         |          |        | 0xF0    |
| 18h     | OFFSI              | OFFSEL[1:0] Reserved MACT[3:0]                      |          |           |         |         |         |          | R/W    | 0x00    |
| 19~37h  |                    | Reserved                                            |          |           |         |         |         |          |        |         |
| 38h     | OSM                | OSM[1:0] Reserved                                   |          |           |         |         |         |          |        | 0x1F    |
| 39~3Ch  |                    |                                                     |          | Rese      | rved    |         |         |          |        | _       |



## Description of Registers

Register 00h: Product identification

| Address | bit7 | bit6 | bit5 | bit4 | bit3  | bit2 | bit1 | bit0 | Access | Default |
|---------|------|------|------|------|-------|------|------|------|--------|---------|
| 00h     |      |      |      | PID  | [7:0] |      |      |      | R      | 0xA5    |

The register contains the GMA305KU product identification code. Always read to be 0xA5.

## Register 01h: Power down control

| Address | bit7 | bit6 | bit5     | bit4 | bit3 | bit2  | bit1 | bit0   | Access | Default |
|---------|------|------|----------|------|------|-------|------|--------|--------|---------|
| 01h     |      |      | Reserved |      |      | PD_BG | RST  | PD_LDO | R/W    | 0x00    |

PD\_BG and PD\_LDO bits manage the on-chip power. When set to 1'b1, the band-gap and LDO will be shut down respectively. All registers values except 01h are lost.

RST is used to reset the chip. When set to 1'b1, core logics will be reset and registers values will return to the default values.

#### Register 02h: Action register

| Address | bit7       | bit6 | bit5 | bit4 | bit3 | bit2 | bit1   | bit0 | Access | Default |
|---------|------------|------|------|------|------|------|--------|------|--------|---------|
| 02h     | Reserved N |      | Not  | used |      | ACTI | R[3:0] |      | R/W    | 0x00    |

1'b1 bit set to the ACTR[3:0] bits will trigger the following actions respectively:

| Bit Set | Action                    |
|---------|---------------------------|
| ACTR[0] | Reset DSP and AFE         |
| ACTR[1] | Stop DSP                  |
| ACTR[2] | Enter continuous mode     |
| ACTR[3] | Enter non-continuous mode |

## Register 03h: Motion threshold

| Address | bit7 | bit6     | bit5 | bit4 | bit3 | bit2     | bit1 | bit0 | Access | Default |
|---------|------|----------|------|------|------|----------|------|------|--------|---------|
| 03h     |      | Not used |      |      | N    | ATHR[4:0 | )]   |      | R/W    | 0x01    |

MTHR[4:0] is used to set the threshold for the built-in motion detect function. The scale factor for the setting is 1 threshold code = 0.25g. Thus the full range of the threshold setting is from 0.25 to 7.75g.

### Register 04h: Start register for data reading

| Address | bit7 | bit6        | bit5 | bit4 | bit3   | bit2 | bit1 | bit0 | Access | Default |
|---------|------|-------------|------|------|--------|------|------|------|--------|---------|
| 04h     |      |             |      | STAD | R[7:0] |      |      |      | R      | 0x0055  |
| U4n     |      | STADR[15:8] |      |      |        |      |      |      |        |         |

For sensor data output, users should read 11 bytes starting from 04h register (STADR) to 0Dh



in one I2C transaction. Note the register has 2-byte word length and its value is fixed to 0x0055. When the I2C data read reach 0Dh, the I2C address pointer will automatically rewind to this start register.

Register 05h: Status register

| Address | bit7   | bit6    | bit5    | bit4      | bit3   | bit2                   | bit1 | bit0 | Access | Default |
|---------|--------|---------|---------|-----------|--------|------------------------|------|------|--------|---------|
| 05h     | RST_DP | PG_DONE | RD_DONE | OTP_VALID | Motion | $\mathbf{C}\mathbf{M}$ | DAOW | DRDY | R      | NA      |

The status register indicates the interrupt and DSP status. The register value will be cleared after reading data by the procedure described in the Register 04h section. Descriptions when the bit is set are summarized below.

- RST\_DP: DSP is stopped
- PG\_DONE: programming OTP data is completed
- RD\_DONE: loading OTP data to DSP is completed
- OTP\_VALID: OTP data is valid when loading OTP to DSP
- Motion: motion interrupt is asserted
- CM: DSP is in continuous mode. Otherwise DSP is in the non-continuous mode.
- DAOW: data has been over-written before read. Otherwise data has not been over-written.
- DRDY: interrupt asserted by new data arrival

#### Register 06h~0Dh: Data registers

| Address | bit7 | bit6             | bit5 | bit4 | bit3  | bit2 | bit1 | bit0 | Access | Default |
|---------|------|------------------|------|------|-------|------|------|------|--------|---------|
| 06h     |      | DX[6:0] Not used |      |      |       |      |      |      |        | NA      |
| 07h     |      |                  |      | DX[  | 14:7] |      |      |      | R      | NA      |
| 08h     |      | DY[6:0] Not used |      |      |       |      |      |      | R      | NA      |
| 09h     |      |                  |      | DY[  | 14:7] |      |      |      | R      | NA      |
| 0Ah     |      |                  |      | DZ[  | [7:0] |      |      |      | R      | NA      |
| 0Bh     |      |                  |      | DZ[  | 15:8] |      |      |      | R      | NA      |
| 0Ch     |      | DT[7:0]          |      |      |       |      |      |      | R      | NA      |
| 0Dh     |      |                  |      | DT[  | 15:8] |      |      |      | R      | NA      |

The XY data output is encoded to a 15-bit value and stored across two bytes. Data representation is 2's complement, i.e. MSB (bit 14) is the sign bit with 1'b1 representing negative value.

The Z data output is encoded to a 16-bit value and stored across two bytes. Data representation is 2's complement, i.e. MSB (bit 15) is the sign bit with 1'b1 representing negative value.

The acceleration sensing has dynamic range of  $\pm 16$ g with sensitivity of 256 LSB/g. The central value (0x00) stands for 0g.



The temperature sensor has sensitivity of 0.5 LSB/°C. The central value (0x00) stands for 25°C.

Typical acceleration reading when GMA305KU is stationary under gravitational field is summarized in the following table and Figure.

| Orientation   | X    | Y    | Z    |
|---------------|------|------|------|
| Orientation 1 | +256 | 0    | 0    |
| Orientation 2 | 0    | +256 | 0    |
| Orientation 3 | -256 | 0    | 0    |
| Orientation 4 | 0    | -256 | 0    |
| Orientation 5 | 0    | 0    | -256 |
| Orientation 6 | 0    | 0    | +256 |



Figure 3: Typical stationary reading in gravity field

Register 15h: Interrupt configuration register

| Address | bit7     | bit6     | bit5     | bit4      | bit3 | bit2    | bit1    | bit0     | Access | Default |
|---------|----------|----------|----------|-----------|------|---------|---------|----------|--------|---------|
| 15h     | Not used | IMEN_NCM | IDEN_NCM | ITYPE_NCM | IPOL | IMEN_CM | IDEN_CM | ITYPE_CM | R/W    | 0x4C    |

The register configures the interrupt control.

- IPOL: control the polarity for the interrupt pin output. Set to 1'b1 for active high and to 1'b0 for active low.
- The other control bits are divided into two groups. Control bits end with \_NCM control the designated features of NCM (non-continuous mode); while bits end with \_CM control those of CM (continuous mode). The common designated features are described below.
  - IMEN: interrupt enable for motion detection. Set to 1'b0 to disenable motion interrupt; Set to 1'b1 to enable motion interrupt.
  - IDEN: interrupt enable for data ready. Set to 1'b0 to disenable data ready interrupt; Set



to 1'b1 to enable data ready interrupt.

■ ITYPE: interrupt push-pull/open drain selection. 1'b0 for push-pull; 1'b0 for open drain.

Register 16h: Control register 1

| Addres | s bit7 | bit6  | bit5   | bit4   | bit3    | bit2  | bit1  | bit0   | Access | Default |
|--------|--------|-------|--------|--------|---------|-------|-------|--------|--------|---------|
| 16h    | MO_EN  | TO_EN | MM_NCM | HP_NCM | MVE_NCM | MM_CM | HP_CM | MVE_CM | R/W    | 0x1B    |

The register controls the DSP configuration.

- MO\_EN: enable the motion transition from NCM to CM.
- TO\_EN: enable the timeout auto-transition from CM to NCM
- The other control bits are divided into two groups. Control bits end with \_NCM control the designated features of NCM (non-continuous mode); while bits end with \_CM control those of CM (continuous mode). The common designated features are described below.
  - MM: enable motion detection to the normal/differential mode. Set to 1'b0 to the normal motion detection mode, or to 1'b1 to the differential mode.
  - HP: enable the high pass filter. Set to 1'b0 to disenable and set to 1'b1 to enable the high-pass filter.
  - MVE: enable the 4-tap moving average. Set to 1'b0 to disenable and set to 1'b1 to enable the low-pass filter.

#### Register 17h: Control register 2

| Address | bit7     | bit6      | bit5 | bit4 | bit3   | bit2 | bit1  | bit0 | Access | Default |
|---------|----------|-----------|------|------|--------|------|-------|------|--------|---------|
| 17h     | Reserved | TOCT[2:0] |      | NCLI | X[1:0] | Rese | erved | R/W  | 0xF0   |         |

TOCT[2:0] is used to set the timeout value for auto-transition from NCM to CM. The timeout values for TOCT setting are summarized below:

| TOCT[2:0] | Timeout (Sec) |
|-----------|---------------|
| 3'b000    | 0             |
| 3'b001    | 0             |
| 3'b010    | 0.5           |
| 3'b011    | 1.0           |
| 3'b100    | 1.5           |
| 3'b101    | 2.0           |
| 3'b110    | 2.5           |
| 3'b111    | 3.0           |

NCLK[1:0] is used to set the ODR in NCM mode as shown in the following:

| NCLK[1:0] | Description  |
|-----------|--------------|
| 2'b00     | 1 Hz NCM ODR |
| 2'b01     | 2 Hz NCM ODR |



| 2'b10 | 4 Hz NCM ODR |
|-------|--------------|
| 2'b11 | 8 Hz NCM ODR |

# Register 18h: Control register 3

| Address | bit7  | bit6    | bit5 | bit4  | bit3 | bit2 | bit1   | bit0 | Access | Default |
|---------|-------|---------|------|-------|------|------|--------|------|--------|---------|
| 18h     | OFFSI | EL[1:0] | Rese | erved |      | MAC' | T[3:0] |      | R/W    | 0x00    |

OFFSEL[1:0] is used to control the offset temperature compensation.

| OFFSEL[1:0] | Description                              |
|-------------|------------------------------------------|
| 2'b00       | Turn off offset temperature compensation |
| 2'b01       | Turn on offset temperature compensation  |
| others      | reserved                                 |

1'b1 bit set to the MACT[3:0] bits will trigger the following actions respectively:

| Bit Set | Action                     |
|---------|----------------------------|
| MACT[0] | Download OTP data into DSP |
| MACT[1] | Reserved                   |
| MACT[2] | Reserved                   |
| MACT[3] | Initialize oscillator      |

# Register 38h: Oversampling mode register

| Address | bit7 | bit6   | bit5 | bit4     | bit3 | bit2 | bit1 | bit0 | Access | Default |
|---------|------|--------|------|----------|------|------|------|------|--------|---------|
| 38h     | OSM  | [[1:0] |      | Reserved |      |      |      | R/W  | 0x1F   |         |

OSM[1:0] selects which oversampling mode is to be used shown in the following Table. The output data rate is always 128Hz for continuous mode (CM). For non-continuous mode (NCM), the output data rate can be set to 1/2/4/8Hz, see Register 17h description for details.

| OSM[1:0] | Oversampling Ratio | Power Scheme    |
|----------|--------------------|-----------------|
| 2'b00    | 64                 | High resolution |
| 2'b01    | 32                 | Low noise       |
| 2'b10    | 16                 | Low power       |
| 2'b11    | Reserved           |                 |



# Digital Interface

#### **I2C Interface General Description**

The I2C interface is compliant with fast mode (400kHz) and normal mode (100 kHz) I2C standard. The 7-bit device slave address is fixed at 0x18.

The I2C bus takes master clock through SCL pin and exchanges serial data via SDA. SDA is a bidirectional (input/output) connection. Both are open-drain connection and must be connected externally to VDDIO via a pull-up resistor.

The I2C interface supports multiple read and write. When using multiple read/write, generally the internal I2C address pointer will automatically increase by 1 for the next access. But exceptions to this general rule are highlighted in the following table. For example, a multiple write to 01h (ACTR) will write multiple bytes sequence to 01h. This will make state transition easily.

| Multiple R/W   | Current Address | Next Address |
|----------------|-----------------|--------------|
| Multiple Write | 01h             | 01h          |
| Multiple Write | 02h             | 02h          |
| Multiple Read  | 0Dh             | 04h          |
| Multiple Write | 18h             | 18h          |

#### **I2C Access Format**

One data bit is transferred for each SCL cycle. The SDA must not change level when the SCL is high. The level changes in SDA while SCL is high are reserved control signals. The SDA and SCL remain high when I2C bus is idle.

Data transfer begins by bus master indicating a start condition (ST) of a falling edge on SDA when SCL is high. The master terminates transmission and frees the bus by issuing a STOP condition (SP). Stop condition is a rising edge on SDA while SCL is high. The bus remains active if a repeated START (SR) condition is generated instead of a STOP condition. Figure 4 illustrates the START and STOP condition.

Figure 4: I2C START and STOP condition



After a start condition (ST), the 7-bit slave address + RW bit must be sent by master. If the slave address does not match with GMA305KU, there is no acknowledge and the following data transfer will not affect GMA305KU. If the slave address corresponds to GMA305KU, it will

Acknowledge



Data output by RECEIVER

Start Condition

acknowledge by pulling SDA to low and the SDA line should be let free by bus master to enable the data transfer. The master should let the SDA high (no pull down) and generate a high SCL pulse for GMA305KU acknowledge. Figure 5 illustrates the acknowledge signal sequence.

SCL from MASTER

Data output by TRANSMITTER

Not Acknowledge

Figure 5: Acknowledge signal sequence

A write to GMA305KU includes transmission of a START condition, the slave address with R/W bit=1'b0, one byte of data to specify the register address to write, subsequent one or more bytes of data, and finally a STOP condition. "Single Write" and "Multiple Write" in Figure 6 illustrates the frame format of single and multiple write to GMA305KU respectively.

Single Write DATA BYTE SLAVE ADDRESS REGISTER ADDRESS SP Multiple Write SLAVE ADDRESS DATA BYTE SP Single Read SLAVE ADDRESS DATA BYTE NA SP Multiple Read SLAVE ADDRESS 0 REGISTER ADDRESS SR SLAVE ADDRESS DATA BYTE DATA BYTE A = acknowledge NA = not acknowledge ST = START condition SR= repeated START condition Master to Slave Slave to Master

Figure 6: I2C access format

A read from GMA305KU starts with transmission of a START condition, the slave address

SP = STOP condition



with R/W bit=1'b0, and one byte of data to specify the register address to read. A repeated START condition and the slave address with R/W bit=1'b1 are transmitted subsequently. The slave address with R/W bit=1'b1 initiates a read operation. GMA305KU acknowledge receipt of the read operation command by pulling SDA low during the 9th SCL clock and begin transmitting the contents starting from the specified register address. The master must acknowledge all correctly received bytes except the last byte. The final byte must be followed by a not acknowledge from the master and the STOP condition. "Single Read" and "Multiple Read" in Figure 6 illustrates the frame format for reading single or multiple byte from GMA305KU.

### **I2C Specifications**

Table 6: I2C Timing Specification

| Parameter             | Symbol                         | Minimum | Typical | Maximum | Unit |
|-----------------------|--------------------------------|---------|---------|---------|------|
| SCL clock frequency   | $\mathbf{f}_{\mathrm{SCL}}$    | _       | _       | 400     | kHz  |
| Clock low period      | ${ m t_{LOW}}$                 | 1.3     | _       | _       | μs   |
| Clock high period     | ${ m t_{HIGH}}$                | 0.6     | _       | _       | μs   |
| Bus free to new start | ${ m t_{BUF}}$                 | 1.3     | _       | _       | μs   |
| Start hold time       | thd.sta                        | 0.6     | _       | _       | μs   |
| Start setup time      | $\mathbf{t}_{	ext{SU.STA}}$    | 0.6     | _       | _       | μs   |
| Data-in hold time     | ${ m t_{HD,DAT}}$              | 0       | _       | _       | μs   |
| Data-in setup time    | ${ m t}_{ m SU.DAT}$           | 100     |         |         | ns   |
| Stop setup time       | $\mathbf{t}_{\mathrm{SU.STO}}$ | 0.6     |         |         | μs   |
| Rise time             | $ m t_{r}$                     | _       | _       | 0.3     | μs   |
| Fall time             | $\mathrm{t_{f}}$               | _       | _       | 0.3     | μs   |
| Spike width           | $ m t_{SP}$                    | _       | _       | 50      | μs   |

Figure 7: I2C Timing Diagram





# Package

## **Outline Dimension**



Figure 8: Package Outline Dimension

### **Axes Orientation**



Figure 9: GMA305KU Axes Orientation

# **RoHS** Compliance

GMEMS QFN sensors are compliant with Restrictions on Hazardous Substances (RoHS), having halide-free molding compound (green) and lead-free terminations. Reflow profiles applicable to those processes can be used successfully for soldering the devices.



### **Surface Mounting Information**

The accelerometer is a delicate device that is sensitive to the mechanical and thermal stress. Proper PCB board design and well-executed soldering processes are crucial to ensure consistent performance. A recommended land pad layout can be found in the below Figure.



Figure 10: Layout Recommendation for PCB Land Pad

### Moisture Sensitivity Level

GMA305KU package MSL rating is Level 3.

### **Tape Specification**



Figure 11: Tape Outline Drawing



Table 7: Tape Dimension

| Symbol         | Dimension (mm) |  |
|----------------|----------------|--|
| A <sub>0</sub> | 3.3±0.1        |  |
| B <sub>0</sub> | $3.3 \pm 0.1$  |  |
| K <sub>0</sub> | $1.25 \pm 0.1$ |  |
| $\mathbf{P}_0$ | $4.0 \pm 0.1$  |  |
| P <sub>1</sub> | $8.0 \pm 0.1$  |  |
| $\mathbf{P_2}$ | $2.0 \pm 0.05$ |  |
| Т              | $0.3 \pm 0.05$ |  |
| E              | $1.75 \pm 0.1$ |  |
| F              | $5.5 \pm 0.05$ |  |
| $D_0$          | 1.5+ 0.1/-0    |  |
| $D_1$          | 1.5            |  |
| W              | $12.0 \pm 0.3$ |  |



# Document History and Modification

| Revision No. | Description                    | Date      |
|--------------|--------------------------------|-----------|
| V1.0         | First release                  | 2016/2/17 |
| V1.1         | Update package from LGA to QFN | 2017/3/29 |
|              |                                |           |
|              |                                |           |
|              |                                |           |
|              |                                |           |
|              |                                |           |
|              |                                |           |
|              |                                |           |